package com.gip.config;

import com.netflix.loadbalancer.IRule;
import com.netflix.loadbalancer.RandomRule;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.client.RestTemplate;

@Configuration
//@Configuration  ---> spring applicationContext.xml
public class ConfigBean {
    //配置负载均衡实现RestTemplate
    // IRule
    // RoundRobinRule 轮询
    // RandomRule 随机
    // AvailabilityFilteringRule ： 会先过滤掉，跳闸，访问故障的服务~，对剩下的进行轮询~
    // RetryRule ： 会先按照轮询获取服务~，如果服务获取失败，则会在指定的时间内进行，重试
    @Bean
    @LoadBalanced //用于负载均衡
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }

    // @Bean
    // public IRule myRule() {
    //     return new RandomRule();//使用随机策略
    //     //return new RoundRobinRule();//使用轮询策略
    //     //return new AvailabilityFilteringRule();//使用轮询策略
    //     //return new RetryRule();//使用轮询策略
    // }

}
